<template>
  <div>
    <BasicForm @register="registerForm" ref="formRef"/>
  <!-- 子表单区域 -->
    <a-tabs v-model:activeKey="activeKey" animated @change="handleChangeTabs">
      <a-tab-pane tab="订单商品" key="ceOrderGoods" :forceRender="true">
        <JVxeTable
          v-if="ceOrderGoodsTable.show"      
          keep-source
          resizable
          ref="ceOrderGoods"
          :loading="ceOrderGoodsTable.loading"
          :columns="ceOrderGoodsTable.columns"
          :dataSource="ceOrderGoodsTable.dataSource"
          :height="340"
          :disabled="formDisabled"
          :rowNumber="true"
          :rowSelection="true"
          :toolbar="true"
          />
      </a-tab-pane>
      <a-tab-pane tab="订单客户" key="ceOrderCustomer" :forceRender="true">
        <JVxeTable
          v-if="ceOrderCustomerTable.show"      
          keep-source
          resizable
          ref="ceOrderCustomer"
          :loading="ceOrderCustomerTable.loading"
          :columns="ceOrderCustomerTable.columns"
          :dataSource="ceOrderCustomerTable.dataSource"
          :height="340"
          :disabled="formDisabled"
          :rowNumber="true"
          :rowSelection="true"
          :toolbar="true"
          />
      </a-tab-pane>
    </a-tabs>
    <div style="width: 100%;text-align: center;margin-top: 10px;" v-if="showFlowSubmitButton">
      <a-button preIcon="ant-design:check-outlined" style="width: 126px" type="primary" @click="handleSubmit">提 交</a-button>
    </div>
  </div>
</template>

<script lang="ts" setup>
    import { defHttp } from '/@/utils/http/axios';
    import {ref, computed, unref,reactive, onMounted, defineProps } from 'vue';
    import {BasicForm, useForm} from '/@/components/Form/index';
    import { JVxeTable } from '/@/components/jeecg/JVxeTable'
    import { useJvxeMethod } from '/@/hooks/system/useJvxeMethods.ts'
    import {formSchema,ceOrderGoodsJVxeColumns,ceOrderCustomerJVxeColumns} from '../CeOrderMain.data';
    import {saveOrUpdate,queryCeOrderGoods,queryCeOrderCustomer} from '../CeOrderMain.api';
    import { VALIDATE_FAILED } from '/@/utils/common/vxeUtils'
    const isUpdate = ref(true);
    
    const refKeys = ref(['ceOrderGoods', 'ceOrderCustomer', ]);
    const activeKey = ref('ceOrderGoods');
    const ceOrderGoods = ref();
    const ceOrderCustomer = ref();
    const tableRefs = {ceOrderGoods, ceOrderCustomer, };
    const ceOrderGoodsTable = reactive({
          loading: false,
          dataSource: [],
          columns:ceOrderGoodsJVxeColumns,
          show: false
    })
    const ceOrderCustomerTable = reactive({
          loading: false,
          dataSource: [],
          columns:ceOrderCustomerJVxeColumns,
          show: false
    })

    const props = defineProps({
      formData: { type: Object, default: ()=>{} },
      formBpm: { type: Boolean, default: true }
    });
    const formDisabled = computed(()=>{
      if(props.formBpm === true){
        if(props.formData.disabled === false){
          return false;
        }
      }
      return true;
    });
    // 是否显示提交按钮
    const showFlowSubmitButton = computed(()=>{
      if(props.formBpm === true){
        if(props.formData.disabled === false){
          return true
        }
      }
      return false
    });
    
    //表单配置
    const [registerForm, {setProps,resetFields, setFieldsValue, validate}] = useForm({
        labelWidth: 150,
        schemas: formSchema,
        showActionButtonGroup: false,
        baseColProps: {span: 24}
    });

    onMounted(()=>{
      initFormData();
    });
    //渲染流程表单数据
    const queryByIdUrl = '/test/ceOrderMain/queryById';
    async function initFormData(){
      if(props.formBpm === true){
        await reset();
        let params = {id: props.formData.dataId};
        const data = await defHttp.get({url: queryByIdUrl, params});
        //表单赋值
        await setFieldsValue({
          ...data
        });
        requestSubTableData(queryCeOrderGoods, {id: data.id}, ceOrderGoodsTable, ()=>{
          ceOrderGoodsTable.show = true;
        });
        requestSubTableData(queryCeOrderCustomer, {id: data.id}, ceOrderCustomerTable, ()=>{
          ceOrderCustomerTable.show = true;
        });
        // 隐藏底部时禁用整个表单
        setProps({ disabled: formDisabled.value })
      }
    }
    
    //方法配置
    const [handleChangeTabs,handleSubmit,requestSubTableData,formRef] = useJvxeMethod(requestAddOrEdit,classifyIntoFormData,tableRefs,activeKey,refKeys);

    async function reset(){
      await resetFields();
      activeKey.value = 'ceOrderGoods';
      ceOrderGoodsTable.dataSource = [];
      ceOrderCustomerTable.dataSource = [];
    }
    function classifyIntoFormData(allValues) {
         let main = Object.assign({}, allValues.formValue)
         return {
           ...main, // 展开
           ceOrderGoodsList: allValues.tablesValue[0].tableData,
           ceOrderCustomerList: allValues.tablesValue[1].tableData,
         }
       }
    //表单提交事件
    async function requestAddOrEdit(values) {
      //提交表单
      await saveOrUpdate(values, true);
    }
</script>

<style lang="less" scoped>
	/** 时间和数字输入框样式 */
    :deep(.ant-input-number){
		width: 100%
	}

	:deep(.ant-calendar-picker){
		width: 100%
	}
</style>